草庐IT

php - Laravel sql 查询第三关系

全部标签

ruby-on-rails - Rails 模型 has_many , belongs_to 关系

我有两个模型classUser我需要在Product表中添加一列user_id还是Rails默认添加它? 最佳答案 您需要手动将user_id列添加到Product模型。如果您尚未创建模型,请将列列表中的引用添加到模型生成器。例如:rails生成模型Productname:stringprice:decimaluser:references或者,如果您的Product模型已经存在,您需要做的是:railsgmigrationaddUserIdToProductsuser_id:integer这将生成一个迁移,将user_id列正确添

ruby-on-rails - 在 rails 中过滤 ActiveRecord 查询

我习惯了Django,在那里你可以在查询集上运行多个过滤方法,即Item.all.filter(foo="bar").filter(something="else")。然而,这在Rails中并不容易。Item.find(:all,:conditions=>["foo=:foo",{:foo=bar}])返回一个数组,这意味着这将不起作用:Item.find(:all,:conditions=>["foo=:foo",{:foo='bar'}]).find(:all,:conditions=>["something=:something",{:something='else'}])所以我

ruby-on-rails - 如何在 Rails 控制台中查看 MySQL 查询

这个问题在这里已经有了答案:HowtoshowSQLqueriesrunintheRailsconsole?(8个答案)关闭8年前。有没有办法在Rails控制台中查看从ActiveRecord触发了哪些MySQL查询?

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir

ruby-on-rails - 将参数值传递给 redirect_to 作为 rails 中的查询字符串

这应该很简单,但我似乎找不到简单的答案。如何将当前请求的参数值传递到redirect_to调用中?我有一些表单值想传递到GET重定向的查询字符串中我想做这样的事情:redirect_to@thing,:foo=>params[:foo]并发送到:http://things/4?[foo][key1]=val1&[foo][key2]=val2谢谢!此外-对于redirect_to:back如何处理?redirect_to:back,:foo=>params[:foo] 最佳答案 redirect_to的“记录”形式仅将第二个参数用于

ruby-on-rails - 获取 fields_for 和 accepts_nested_attributes_for 以处理 belongs_to 关系

我似乎无法使用Rails2.3的新accepts_nested_attributes_for工具在RailsView中为belongs_to关系生成嵌套表单。我确实检查了许多可用的资源,看起来我的代码应该可以工作,但是fields_for对我来说是爆炸性的,我怀疑它与如何做有关我配置了嵌套模型。我遇到的错误是一个常见的错误,可能有多种原因:'@account[owner]'isnotallowedasaninstancevariablename下面是涉及的两个模型:classAccount'User',:foreign_key=>'owner_id'accepts_nested_att

sql - 通过关联的 Rails 查询仅限于最近的记录?

classUserhas_many:books我需要一个返回的查询:最近一本书具有:complete=>true的用户。即,如果用户最近的书有:complete=>false,我不希望它们出现在我的结果中。到目前为止我有什么User.joins(:books).merge(Book.where(:complete=>true))这是一个很有希望的开始,但没有给我需要的结果。我试过添加.order("created_ondesc").limit(1)到上述查询的末尾,但是当我期待很多结果时,我最终只得到一个结果。谢谢! 最佳答案 如果

ruby-on-rails - Rails ActiveRecord 查询日期范围

我正在尝试在我的Controller中使用以下行来捕获从当前日期起不到一周的所有任务:@due_this_week=current_user.tasks.where(due_date:Date.today..1.week.from_now)出于某种原因,它没有找到任何结果,即使我知道我有四到六天的任务到期。这是唯一使用范围查询的实例变量。我有另一个可以很好地查找逾期任务的工具:@overdue=current_user.tasks.where("due_date我错过了什么? 最佳答案 应该是:@due_this_week=curr

ruby-on-rails - 在搭建脚手架时创建关系

大家好,我是RubyonRails的新手。我正在尝试创建一个小型博客站点。我有两个表帖子和评论。每个帖子都会有很多评论。我使用这些命令生成表格。railsgscaffoldPosttitle:stringbody:textauthor:stringrailsgscaffoldCommentbody:stringauthor:string现在我想将关系添加到模型类中。我将has_many:comments添加到Post类,将belongs_to:post添加到Comment类。但是,当我尝试调用post.comments时,出现运行时错误,提示SQLException:nosuchcol

ruby-on-rails - ActiveRecord 查询中的 “includes” 和 “preload” 有什么区别?

我正在努力寻找ActiveRecord对象的includes()和preload()的比较。谁能解释一下区别? 最佳答案 Rails有两种方法可以避免n+1问题。一个涉及创建一个基于大连接的查询以拉入您的关联,另一个涉及为每个关联进行单独的查询。当您执行includes时,rails会决定为您使用哪种策略。它默认使用单独的查询方法(预加载),除非它认为您正在使用条件或订单中关联的列。因为这只适用于joins方法,所以改用它。Rails的启发式方法有时会出错,或者您可能有特定的原因偏爱一种方法而不是另一种方法。preload(及其配套